c++ - MSVCP110D.dll 和 Visual Studio 2013
全部标签 这是一道关于gtk/glib/libpango/libcairo的概念题。让我们直奔问题。我正在用一位前同事用Go编写的旧C库进行包装,在C代码调用的某处pango_cairo_font_map_get_default()获取由libpango维护的默认font_map。包装基本上是从Go域进入C域(外部函数接口(interface))和C端使用pthread创建一个线程最终调用pango_cairo_font_map_get_default。最初,在纯C端一切正常。包装后,C代码卡在调用pango_cairo_font_map_get_default()printf("beforec
我正在使用go插件包,按照指南,他们说我应该使用buildmode=plugin创建一个iso文件,输出应该有扩展名so。这是经验法则吗?我应该总是添加扩展名吗?还是品味问题?谢谢! 最佳答案 通常,插件(有时称为共享/动态库)具有依赖于它们运行的平台的扩展。对于Windows,该扩展名往往是.dll(“动态链接库”)。但是,在撰写本文时,Go不支持Windows插件。对于Linux/BSD系统,该扩展名往往是.so(对于“共享对象”)这是Go文档推荐您使用的。在documentationforthepluginpackage之
我正在尝试学习Cgo,所以我尝试从Cgo访问aerospike客户端packagemain//#cgoCFLAGS:-g-Wall//#include//#include//#include"aerospike-client-c/examples/put/example_utils.h"import"C"import("unsafe")funcmain(){retvals:=C.putitnew()_=retvals}但我遇到以下错误。(请注意,当我执行make和makerun时,C程序运行成功)。undefinedreferenceto`example_get_opts'./aero
我正在探索CGO,我遇到了一个怪癖,在go运行时中C.int的大小是8个字节,但Cint是4个字节。我知道Goint可以是64位或32位,具体取决于体系结构,而Cint始终是32位。是有一种标准方法可以告诉go对C.int类型使用4个字节吗?我无法找到处理此问题的文档。因此,代码无法按预期运行。它基本上将低端添加到第一个int的高端。它从不引用传递的第二个int。提前致谢。实际输出:0xc00001a0b00xc00001a0b80xc00001a0b00xc00001a0b41990199主.gopackagemain/*intaddNums(int*nums);*/import"C
我想通过Go使用附带的Mono框架执行HelloWorldConsole.exe。所以我想调用mono-2.0-sgen.dll函数“mono_main”来执行exe。mono-2.0-sgen.dll是适用于MSWindows的PE32可执行文件,see.但我收到错误“不是有效的Win32应用程序”_=os.Setenv("MONO_PATH",`\mono\lib\mono\4.5;C:\DEV\HelloWorldConsole\HelloWorldConsole\bin\Debug`)_=os.Setenv("MONO_CFG_DIR",`"C:\ProgramFiles(x8
我有以下GO代码:packagemainimport("syscall")funcmain(){varmod,_=syscall.LoadLibrary("user32.dll")}成功加载user32.dll文件。(这是我在网上找到的一个例子的修改版本)。但是我不知道这个DLL存在于文件系统的哪个位置。我一直在寻找一种方法让Go能够通过syscall库告诉我这一点,但还没有找到实现它的方法。有谁知道获取已加载DLL路径的方法吗? 最佳答案 我现在无法访问运行Go的Windows机器,但它应该是这样的。请注意代码中缺乏适当的资源/错
我正在尝试使用Golang在Windows上加载ChakraCore.dll,但我无法弄清楚我需要将什么参数类型作为第三个参数传递。我阅读librarycode的假设并松散地遵循EmbeddingChakraCore是第三个参数需要是空指针指针(void**),因为头文件将JsRuntimeHandle定义为typedefvoid*JsRuntimeHandle;如果可能的话,我也希望避免使用CGo。控制台输出:panic:JsCreateRuntimefailed:AnargumenttoahostingAPIwasnullinacontextwherenullisnotallowe
这两个步骤:gcc-cmain.cgcc-oa.exemain.oMyThing.dll非常适合制作可以调用MyThing.dll内部方法的Windowsexe。注意没有-c的gccmain.c会给出如下错误:未定义对MyThing_method的引用但是,当尝试使用cgo在Golang程序中使同一个系统工作时,我遇到了与使用没有-c的gcc时相同的undefinedreference错误。我读过:https://github.com/golang/go/wiki/WindowsDLLs并且很想尝试使用syscall.NewLazyDLL但我的问题是我的foo.go文件正在调用C.So
我正在尝试将Go函数传递给C函数。类似于:stm:=C.struct_tray_menu{....fn://definitionofmethod....}C.menu_cb(stm);并将其传递给C函数:staticvoidmenu_cb(structtray_menu*item){(void)item;printf("menu:clickedon%s\n",item->text);}我只是想知道如何定义像C.function这样的东西。 最佳答案 主要问题是对c中go定义的误解。所以最终代码看起来像//exportcallOnMe
我正在尝试使用GoogleProtocolBuffers与Go中的C库进行通信,但我无法使其正常工作。我在尝试将protobuf发送到C库时遇到错误我将发布最少的代码来重现我现在面临的错误(我删除了大部分C部分,因为它与此错误无关):/*#cgoCFLAGS:-I@CURRENT_SOURCE_DIR@/../../library/crnd/include-I@CMAKE_CURRENT_BINARY_DIR@/../../library#cgoLDFLAGS:-L@CRND_LIBRARY_PATH@-lcrnd#include#include#include#includetype